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(54) Method and system for adaptive bandwidth allocation in a high speed data network 



(57) This adaptive bandwidth allocation for Non- 
Reserved traffic over high speed transmission links of a 
digital network is operated through regulation of data 
packet transfers over network nodes/ports including 
input/output adapters connected through a switching 
device. 

To that end the network node is assigned with a 
Control Point computing devise (CP) storing a Topology 
Data Base keeping an image of the network. 

This Data Base is periodically and at call set up 
updated by Topology Data Base Update messages 
(TDUs) including an Explicit Rate parameter for link I 
indicating the current available bandwidth on link I, and 
a parameter N NR | indicating the number of Non- 
Reserved connections on link I. 

These informations are used within each Adapter to 
periodically regulate the transmission bandwidth 
assigned to each Non-Reserved traffic connection 
within the network. To that end, each adapter is pro- 
vided with an Access Control Function device for each 
attached connection (data source) and a Connection 
Agent (CA) getting, on request, required current link 
informations from the attached Topology Data Base. 
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Description 

Field of the Invention 

5 This invention relates to a method and system for adaptively and dynamically operating bandwith allocation to so- 

called Non- Reserved Bandwidth traffic in a high speed-data transmission network. 

Background of the Invention 

10 Modern digital networks are made to operate in a multimedia environment for transporting different types of data 
(pure data or digitized information signals including voice, image, video, etc) over the same network, while ensuring the 
compliance with the requirements specific to each kind of these traffics. 

For instance, one may notice that the information provided by various users can be divided into different types. 
These include real-time information (such as voice information) that must be transmitted to the end-user with predefined 
15 limited time-delay restrictions, and non-real-time information. If some real-time information is not transferred within said 
time delay, it should simply be discarded. 

In this case, recovery of the original signal, at end-user location is made possible to some extent, by providing tech- 
niques such as interpolation/extrapolation techniques, in a data packet transmission environment. These techniques do 
provide solutions to overcome the "loss" of only a limited number of discarded consecutive packets. They do not over- 
20 come the delay restriction requirement. 

On one hand the information may be considered as including : a so-called Reserved traffic information whose 
transmission must be guaranteed with predefined maximum delay according to conditions contractually agreed upon 
by both parties, i. e. end-user and network owner ; and a Non-Reserved (NR) information, such as certain control infor- 
mation or traffic of specific sources to be vehiculated over the network with no specific time constraint, but which traffic 
25 should be optimized for network efficiency. 

On the other hand, one should recall that different techniques have been developed, such as packet switching tech- 
niques, whereby the digitized data are arranged into so called bit packets as already mentionned, and circuit switching 
techniques. 

The basic advantage of packet switching techniques as compared to circuit switching techniques, is to allow a sta- 
30 tistical multiplexing of the different types of data over a line which optimizes the transmission bandwith. The drawback 
of packet switching techniques compared to circuit switching techniques, is that it introduces jitter and delay, which, as 
already considered, may be detrimental for the transmission of isochronous data, like video or voice. This is why meth- 
ods have been proposed to control the network in such a way that delays and jitters are bounded for every new connec- 
tion that is set-up across a packet switched network 
35 These methods have been described, for instance a co-pending European Application 94480097.8 . All these 
methods include, for any end user requesting service or any control data to be vehiculated over the network, establish- 
ing a path through network high speed links (or lines) and nodes or ports, with optimal use of the available transmission 
bandwidth. 

Basically, one may allocate predefined bandwidthsto Reserved traffic (including real-time) on the basis of contrac- 
40 tually defined parameters, and then allocate whatever left in the bandwidth to Non-Reserved traffic on fixed basis. 

But, bearing in mind that instantaneous traffics are eminently variable for both Reserved and Non-Reserved traf- 
fics, any fixed bandwidth assignment is naturally inefficient as far as the efficiency of global network utilization is con- 
cerned. 

A first improvement consists in precomputed oversized bandwidths allocations on a source by source basis, with 
45 the provision of means for detecting instantaneous congestions occurring within the network and for monitoring some 
sort of "slowing-down" mechanism. Such a mechanism has already been described in the above mentioned copending 
European Application as well as in US patent 5 280 470. In the mentioned co-pending application, the slowing-down 
mechanism is only used to control congestion at node switching level through management of a switch back-pressure 
signal. In the US patent 5 280 470 slowing<Jown is operated over reserved bandwidths only when congestion is 
so detected in network nodes and no increase is allowed, which may result in low link utilization in case of some sources 
being non-active. Accordingly, the data sources are not really taken into account on a dynamic basis. In other words, 
the considered prior art system does not provide true dynamic sharing among connections but only helps resolving traf- 
fic congestions temporarily by sending a slow-down message back to sources. 

55 Objects of the Invention 

One object of this invention is to provide a method for optimizing bandwidth allocation to Non- Reserved traffic in a 
data communication network. 

Another object of the invention is to provide a method for monitoring Reserved traffic and dynamically assigning or 
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adapting transmission bandwidth to Non-Reserved traffic accordingly in a data communication network. 

Still another object of the invention is to provide a method for dynamically and fairly distributing transmission band- 
width among Non-Reserved traffic sources, based on real data sources requirements, in a communication network 
operating in Asynchronous Transfer Mode (ATM), or Frame relay. 

These and other objects, characteristics and advantages of the invention, shall be more readily apparent from the 
following description of a preferred embodiment made with reference to the accompanying drawings. 



Summary of the Invention 



10 This invention deals with an adaptive bandwidth allocation method for optimizing data traffic in a high speed data 
transmission network including Nodes interconnected by high speed links made for vehiculating data traffics of different 
priority levels along assigned network paths between data terminal equipments acting as data sources and data desti- 
nation terminals, said priority levels including high priority level(s) for so-called Reserved traffic for which a transmission 
bandwidth has been reserved along said assigned path based on predefined agreements, and low priority level for so- 

15 called Non- Reserved traffic which should be transferred over the network within the transmission bandwidth available 
along the considered path once Reserved traffic is satisfied, said method for assigning bandwidth to Non-Reserved traf- 
fic including : 



generating and keeping at least one Topology Data Base storing an image of the network occupancy over each link 
20 along the network paths; 



periodically and at any terminal call set-up within the network, generating and broadcasting Topology Data Base 
updating (TDUs) messages, said TDU messages including a so-called Explicit Rate parameter (ER|) for each link 
I indicating the bandwidth currently available on link I, and a parameter N NR indicating the number of Non-Reserved 
25 connections on link I; 

upon receving said TDUs information, computing for each node along the considered path the amount of transmis- 
sion bandwidth left available over each link along the considered path and assigning said available bandwidth to 
the Non- Reserved traffic sources connected to the network. 

30 

Brief Description of the Figures 

Figure 1 is a schematic representation of an example of data transmission network made to include the invention. 
35 Figure 2 is a schematic representation of the device made to implement the invention within one network node. 
Figure 3 is a detailed representation of the system made to implement the invention within one node adapter. 



Figure 4 is a schematic representation of a device to be used within the invention. 

40 

Figure 5 is a detailed flow-chart made to implement the invention. 
Detailed Description of a Preferred Embodiment of the Invention 

45 While the invention applies equally to both centralized control networks and distributed control networks, the pre- 
ferred embodiment shall herein be described with reference to a distributed control data transmission network There- 
fore, in no instances should this be considered as implying any limitation to the invention. 

Accordingly, Figure 1 shows an example of a packet switching network with distributed control, (i. e. control at each 
node of the network), which can be used to implement the invention. This network includes five switching nodes SWO 

so to SW4 interconnected by high speed trunk lines (or links) (10, 11 , 12, 13 et 14) and that can be accessed by access 
lines (AL's) connected to outside data terminal equipments (DTE's) acting as data sources or destination terminals. 

The network control architecture being a distributed one, each switching node is controlled by a control point CR 
All CP's are interconnected via a control point spanning tree (CPST) which provides an efficient means for multicasting 
control messages between the control points. When a CP wants to broadcast a control message to other CP's in the 

55 network, it sends this message to the predefined CPST switching address, and the architecture provides the means to 
route this message on every line of the CP spanning tree, and only on these lines. This architecture also provides the 
means to initialize the tree address on each switching node, and to automatically reconfigure the tree in case of line or 
switching node failure. 

Each CP includes a copy of the Topology Data Base that contains the information about the network. It includes the 



3 

BNSDOCID: <EP 0781066A1_I_> 



EP0 781 068 A1 

network physical configuration and the line characteristics and statuses. 

For every line I, in the network, vehiculating a so-called Reserved traffic, the maximum delay T(n) that can be 
accepted on a packet with a specified priority, and the level of bandwidth utilization R_res(n) on this line are defined and 
recorded in the topology data base. This information is distributed to other control points via topology data base update 
5 messages (TDU S ) sent over the control point spanning tree whenever required. 

For more informations on such a Spanning Tree organization, one may refer to the Copending European Patent 
Application number 94480048.1, with the title "A Data Communication Network and Method for Operating said Net- 
work". 

In operation, any source user terminal equipment may request being connected to a destination terminal. For 
10 instance user terminal equipment DTE-A and DTE-B which are respectively connected to the network via access lines 
AL-A and AL-B, shall be interconnected thru the network with a given quality of service (QoS) specified in terms of a 
maximum delay T-max and a packet loss probability P-loss, upon DTE-A requesting being connected to DTE-B (i.e. at 
DTE-A call set-up) . 

To that end, at the switching node SWO, the control point CPO first uses the QoS and the traffic characteristics spec- 
75 if ied by the user (peak rate, mean rate, average packet length) to compute the amount of bandwidth C_eq, called the 
equivalent capacity of the connection to be reserved on every line, on the route or path assigned to the traffic between 
source terminal and destination terminal, in order to guarantee a packet loss probability P0(n) on this line which is 
smaller than the loss probability PJoss that has been specified for the connection. 

Based of the information that is available on a line basis in the topology data base, the control point CPO then com- 
20 putes the best route in the network to reach the destination. To that end, a Path Selection Program first identifies the 
network lines that are eligible for the route. If R(n) and R_res(n) respectively denote the capacity of line n and its current 
level of reservation, then the line is eligible if : 

R_res(n) + C_eq <> 0.85 R(n) 

25 

it then uses a modified Bellman-Ford algorithm to find the minimum weight, minimum hop count, route from the origin 
to the destination which uses eligible lines and which satisfies the QoS. 

T_max < ZT(n) 

30 

PJoss < 1-7r(1-P_l(n)) 

where the summation and product* operators are carried over the N lines of the route (n=1 N). 

For additional information on equivalent capacity and best route considerations, one may refer to the following pub- 
35 lications : 

R. Guerin, H. Ahmadi, M. Naghshineh, "Equivalent Capacity and its Application to Bandwidth Allocation in High 
Speed Networks", published in IEEE Journal of Selected Areas in Communications, JSAC-7, Sept. 1991. 

40 - H. Ahmadi, J. S. Chen, R. Guerin, L. Gun, A. M. Lee and T Tedijanto, "Dynamic Routing and Call Control in High- 
Speed Integrated Network", pusblished in Proc. Workshop Sys. Eng. Traf. Eng., ITC 13, pp 397-403, Copenhagen, 
Denmark. 

Now, let's assume that the chosen route to connect DTE-A1 to DTE-B from switching node SWO to switching node 
45 SW4 uses trunk lines 10, 1 1 and 14 via switching nodes SW1 and SW2 and access lines AL1 on switching nodes SWO 
and SW4. 

To that end, the origin control point CPO sends a connection set-up message along the route, a copy of which is 
delivered to the control point of every switch on the route (e. g. CP1 , CP2 and CP4). This message contains a list of the 
network addresses of the control points on the route, the list of the link names (e. g. 10,11,14) between these control 
so points, the request bandwidth C_eq, the priority of the connection, and a connection correlator C_cor which is set by 
the origin control point CPO and which is used by all other CP's to uniquely identify the connection. 

Upon reception of the copy of the set-up message, each CP performs two basic tasks. 

First, the CP checks whether the equivalent capacity of the new connection is still available on the line to the next 
switching node on the route, and if it is available, it reserves it. Therefore, the CP checks whether the line is eligible by 
55 verifying the first above relation. If it is. the CP reserves the desired amount of bandwidth on the transmit line for the 
new connection, accepts the connection set-up, increments the reservation level : 

R_res(n) = R_res(n) + C_eq 
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and if this reservation level has significantly changed, it eventually broadcasts a topology data update (TDU) message 
on the CP spanning tree to inform the other CP's of the new reservation level R_res of this particular line. 

Second, the CP allocates a new label for the new connnection, and sends back this label to the control point of the 
previous switch on the route, for label swapping purposes. 

5 Accordingly, during network operation, each node n (n=0, 1 ,...) Control Point (CPn) periodically, and at call set-ups, 

broadcasts Topology Data-Bases Updating (TDUs) messages collected by access nodes. Now, for the purpose of the 
dynamically adaptive control of the network bandwidth allocation of this invention, the TDU format shall be made to 
include a so-called Explicit Rate (ER) parameter. Accordingly, as represented in Figure 1, the TDU format for any link I 
shall include, in the above mentioned TDU messages, the Explicit Rate for link I (i. e. ERI) which ERI shall specify the 

w current available bandwidth on the link I divided by the number of NR connections, and therefore indicate dynamically 
said available bandwidth to the corresponding Control Points. This information shall enable adaptively assigning band- 
width to sources requesting service for transmitting the so-called Non-Reserved (NR) traffic, with a full knowledge of 
the bandwidth currently available on all considered links. 

Assuming the traffic to be vehiculated from source terminal DTE-A1 to destination terminal DTE-B, through the 

is above mentioned path SWO, 10, SW1, 11, SW2, 14, SW4, then each of these node Topology Data Bases shall have 
available the Explicit Rates on the node connected trunks. 

In addition, the TDU format over link I shall also include an indication of number of Non- Reserved connections on 
said link I, (i. e. : N NR |). 

Given these pieces of informations, not only the access node (SWO) Control Point is made capable of defining 

20 whether Non- Reserved traffic from DTE_A may be sent over the network but in addition the network organization 
makes it possible to fairly and dynamically adjust the bandwidths distributed among the link connected Non- Reserved 
sources in order to mimize the data packets lost, without impacting on Reserved traffic. 

Represented in figure 2 is a block diagram showing the various devices used within any given node, e. g. Node zero 
including a switching device SWO and attached Control point device CPO. The switching device SWO includes several 

25 adapters each being connected to one line or link said adapters are labelled Adapter 0, Adapter 1, Adapter n. One 
line may handle up to thousands of connections to traffic sources. For example, traffic sources labelled 21 . 22, 23 are 
represented attached to Adapter 0. 

The data traffic of each source is oriented toward an Access Control Function device (see 24, 25, 26). Said Access 
Control Function devices are attached to an Adapter Control Agent (CA) in both directions. Each Control Agent (CAO, 

30 CA1, ... CAn) is attached to the node Control Point (CPO) to get, on request, link information for local connections 
attached, from the corresponding Topology Data Base. Also, as already mentioned, the CPO Topology Data Base gets 
the Topology Data Update (TDU) messages (e.g. TDU 1 1 , TDU 12...) from the network links (see figure 1). 

Represented in figure 3 is an illustration of the operation of an Access Control Function (ACF) device 30 and a Con- 
nection Agent (CA) Device 31 . To understand the operation of this system, one should first remember that the data traf- 

35 f ic from any user is organized into packets (or ATM cells herein considered as packets) the transmission of which, over 
a node output line, is regulated. Various regulating methods are known in the art. One of these methods utilizes a so- 
called Leaky Bucket mechanism. A leaky bucket mechanism is illustraed in figure 4. Basically in the mechanism shown 
in figure 4, the data packets to be transferred are first passed through an admission buffer or shift register arrangement 
4T . The transfer from admission buffer to the network line is regulated by a token pool. To that end, a "token" generator 

40 is made to generate tokens at a predefined rate and said tokens are stored into a token pool 42. Then, each data packet 
to be transferred from the admission buffer 41 , to the network, shall request as many tokens as the data packet contains 
bytes . Should these tokens be available in the token pool 42, the considered data packet shall be passed to the net- 
work. Otherwise the data packet should wait until the number of tokens has been generated. Since the tokens shall be 
individually attached to the requesting data packets, the mechanism may be improved to enable discriminating among 

45 discardable and non discardable data. Therefore, at the leaky bucket level, processing discrimination between discard- 
able packets and non-discardable packets shall be performed through duplication of the token pool. To illustrate this, 
non-discardable packets shall have been tagged with a so-called green tag and discardable packets shall have been 
tagged with a so-called red tag. Accordingly two token pools are then used, one for "green" tokens and one for "red" 
tokens. Both pools are fed-in independently from each other. The green token pool is fed with a token rate C_eqW equal 

so to the equivalent capacity that has been reserved for the connection k in the network, or with a token rate MCR k which 
is the minimum guarateed bandwidth for NR. The red token pool is fed with a token rate R k ,. While the computation of 
C_eq is described in the above mentioned references, the adaptive computation of the R k t is an object of the present 
invention. 

For instance, discardable data packets may include voice data packets recoverable at receiving end through sev- 
55 eral known mechanisms, e. g. interpolation/extrapolation mechanisms. But what is more important for the present 
invention is that the data packets transfers through the leaky bucket mechanism may be regulated by controlling the 
token generation rates. This is why, turning back to figure 3, one may notice that the Leaky Bucket 32 of the Access 
Control Function device (24) for a data source k is attached to a variable rate token pool 33. Said token pool 33 is also 
provided with threshold reference indications (a low threshold reference TH L and a high treshold reference TH H ) to be 



BNSDOCID: <EP 078106SA1_I_> 



EP 0 781 068 A1 



used for regulation purposes. The token pool level with respect to these thresholds shall indicate the measure of utili- 
sation and define whether the token generation rate should be increased, decreased or kept even (i. e. not changed). 

For every connection along the considered path the token generation rate Ft k t is updated by a mechanism. For 
instance, the Token Rate computing mechanism 31 for connection k, shall update the token generation at time t by pro- 
viding an updated token generation rate R kt . This is made possible first through the use of a parameter measuring the 
utilization on connection k (device 35) monitored by the token pool 33 and indicating whether the token generation rate 
should be increased, decreased or not changed, for instance, based on monitoring the token pool level with reference 
to TH H and TH L . 

The informations provided by all the token utilization devices, such as 35, attached to the individual local connec- 
tions of the Access Control Function device 30 attached to the considered access link, are fed into an allocated band- 
width computing device 36 within the Connection Agent device 31. This computing device 36 keeps tracking the 
bandwidth currently allocated to each connection k of the considered port. The computing device 36, in turn, drives a 
rate updating device 37 controlling the token rate device 34. The computing device 36, is provided, upon request, with 
all required Explicit Rates (ER,) and numbers of Non- Reserved connections (N NRI ) available in the Topology Data Base 
as updated by the various TDU S ) fed into the considered node Control Point (e. g. CPO) to enable computing the 
updated token generation rate R| k t to be assigned to the connection k ou link I at time t, and then drive the token rate 
generation 34. 

In operation, the system gets periodically leaky bucket measures and is able to decide if a connection needs its rate 
to be increased (i) decreased (d), or kept even (i. e. unchanged) (e). 

Let Lk be the set of links along the path of connection k. To determine the rate allowed to the connection k of the 
local port (e. g. SWO for DTE_A) one first needs to know the portion B, t of the bandwidth allocated to all the connections 
of the port, for every link I belonging to along their path. B, t is given by : 



B l t = ER | x N 



(1 -(Rho) res j t ) CI - £ MCR 



k 



Nnr. ' 
wherein : 

Nj is the number of Non- Reserved connections attached to the local port that have link I in their path ; 

ER| is the explicit rate for link I ; 

(Rho) res , t is the bandwidth ratio used by reserved traffic on link I at time t, statistically monitored on the network 
nodes considered. 

C| is the link I speed ; 

n nri 's the total number of Non-Reserved connections within the network that have link I on their path. 

MCR k is the fraction of bandwidth "reserved" for Non Reserved traffic of connection k. (Eventhough this 

parameter MCR k should be null for Non-Reserved traffic, one may optionally reserve a fair minimum 
bandwidth anyway, for that traffic). In other words 

^ MCR k would be the sum of the Minimum Cell Rates 



would be the sum of the Minimum Cell Rates (MCR) (if any) of all Non-Reserved connections sharing 
link I. 

Then, using the leaky bucket measurements for the local node at time t - 1 , the new explicit rates R k t for sources 
attached to this node should be computed for time t. 
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Using informations from the leaky bucket, the system can deduce the number N (l >| , of connections bottlenecked 
asking for more bandwidth, , from connections which do not use alt their bandwidth and therefore can release some 
of it, N< e >| t of connections which use the bandwidth they need and do not need more (N ,=N (l) lt +N (d) , t +N (e) , t ) . Note 
that this classification based on whether the rate of connection k should be increased, decreased or unchanged only 
s depends on the current value set at the local node, R kt -1 . 

For a given connection k, we will use the current rate Ri^.m set on link 1 at t' me *~ 1 anc * re-write R^k.m as R (d \ k ,t-1 
if connection k needs a decrease, R^i^.m if connection k needs an increase and R (e) i t k,t-1 if connection k can be held 
to its current rate. The computation of the rates R| k t is done according to the following recurrent system on every link I 
of k : ' ' , 

10 

0 if decrease, 

R . B '.t m (d) , 1 

"i,k,t ~ r L" l,k,M- a i.t J 

0 if no change, 

B || (( ( 

20 R lkt = [R l.k.t-l-^l.t+P'l.t] 

b l,M 



0 if increase, 



25 



30 



35 



N(i) 



l,t 



B l t 1 



Bl,t-1 NTTT7^ t 

3 = 1 



where a', , and a"| , are multiplicative decrease factors and P'| t and p" { t are additive increase factors. 
The rate of connection k is then set to the minimum rate computed along its path : 

40 Rk, t = min < R 1 ,k,t) 

l6L k 

and then, 

45 

R kt = max {MCR k , min {PCR k , R k ,}} 

The underlying assumption for this model is that all connections should be able to release at any time the band- 
width they got in order to satisfy a defined fairness criterion. For instance, if at an arbitrary time there are only connec- 

so tions which ask for an increase and connections which are "ok", it is not fair that this state for the previous system be 
stable : some of the bandwidth allocated to the connections "ok" should be re-distributed among the bottlenecked con- 
nections. The fairness criterion chosen here means that a state where all connections need more bandwidth than the 
network can offer is a more fair state than the unbalanced state mentioned here above. This is, naturally, but one of the 
fairness criterion which could be used. 

55 The sum term in the equation for connections which need more bandwidth is also used to achieve some fairness 
among them. Without this term (L e., simply using R (l \ k(t -i), connections which already have a significant amount of the 
total bandwidth and ask for more will never release part of what they got in favor of connections with small rates which 
suddendly ask for bandwidth. As this scenario is not fair, the global bandwidth of connections waiting for an increase 
should be equally redistributed (according to the max-min criterion). 
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At last, the term B, t /B, M equally distributes over all connections the variations of the available bandwidth for non 
reserved traffic on link I. 

The problem for computing a'j t , a"| t , P', t and P", t is not simple, as they are function of one or more of the time var- 
iables N (l \ t , N< d )| N (e) | t . As a consequence, they are themselves function of time. Moreover, these parameters should 
always satisfy, for link I, that 



10 



N, N , 

S R "j.t = B l,t /B l,t-1 X X R lj,M 



j-1 



j=1 



The resolution of the system being too complex to be evaluated for each time t, an heuristic approach should be 
employed : 

15 0 For connections which should decrease, a' ( t is of course 

less than one and should be closer to 0 as the number of connections which need bandwidth is high. Some of the 
bandwidth released should also be added to connections which need no change, i. e., is part of the p' (t term. We 
set : 



= 1 - 



,(i)2 



N (i) , t N (e) , 
N 2 , 



(1) 



25 0 For connections which should need equal bandwidth, a" M should also be closer to 0 as the number of connec- 
tions which need bandwidth is high. 



= 1 



N 



(i)2 



30 



(2) 



On the other hand, the rate of these connections grows up by applying N^, t N (e) , t /N 2 | on connections which release 
bandwidth. 

35 This amount is equally distributed over the N (e) )t connections ; 
this gives : 

N (0 N(< % 



0 For connections which should increase, the term p"| t is the total bandwidth released by applying the term 
N^ 2 | t /N 2 | on both previous sets of connection rates, equally distributed over the } connections : 

45 

n( 1 ) ± t 

0*'i,t = ! C s R( d >i /t -i + z: R (e) i,j,t-i ) (4) 

so N 2 ! j = l j=l 



55 

The algorithm used to implement the invention may be summarized as follows : 
For all connections : 
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0 using the leaky bucket statistics, "mark" connection k as requiring an increase, decrease, or no change. 
For all links : 
5 0 Compute N<\ ti N< d > M and N< e ) M 

0 Upon reception of a TDU message, update the available bandwidth available on each link I: 



w 



15 



20 



30 



40 



50 



55 



N NRI 

(1 -(Rho) re3 lt )C, - £MCR k 
B.^ER.xN, _ ^ N, (5) 

l>J NRI 

N<\ t N\ t N<% 

0 Compute 2 R (d) IJiM . £ R (0 IJtM and £ R (e) IJiM 
i=i ]=1 j=i 



For all connections : 

0 For all links in connection path, update R| k t 
25 - if decrease. 



B„ m H W n N < \,N W „ 



if no change, 

q N «2 N (o N (d, l>t 

35 R _ U r R (e) _ ™ jj N My V R (d) 1 (7\ 



i.m ' ' N , NTI 



if increase, 

n( 1 ) i t w(d) 1 t 

Bl t 1 ' N(i)x t 

*l,k,t = — [ , . , = R(Dl,d,t-l + C SR(d) 1JfM 

Bl,t-1 * Cl) l,t 3 = 1 N*x j = l 

N(e) x t 

+ 2 ' R(e) l,3,t-1 > 3 (8) 

3 = 1 



0 and set 



R k/t = min {Ri /k/ t> ( 9 ) 
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R kt = max {MCR k , min{PCR k , R kt }} (10) 

5 In practice, it is expected that the non-reserved traffic will be mostly bursty with long idle periods. Because of these 

silent phases, it is reasonable to think that only a few connections will be active and then performances would be 
increased by introducing some statistical multiplexing. Basically, this means that we could allocate to every connection 
a "little bit more" than its rough fair share, as long as there is no congestion within the network. 

Represented in figure 5 is a block diagram of the algorithm for implementing the invention and getting the rate 
10 adjusment looked for, for a connection k. 

First, a measure of utilization as defined by device 35 (see figure 3), as well as the measures of utilization of all 
other local connections (1 , 2, 3, ...k-1) is provided to a computing stage 50. Said computing stage also gets the rates at 
t-1 from a TABLE stored in the Connection Agent (CA) considered. Said table looks as follows : 

15 

TABLE 





link 1 i link 2 




link 1 


Connection 1 


^1 ,1,1-1 




R i,i,t-i 


Connection 2 
















Connection k 






R l,k,t-1 



25 

The computing stage 50 (see figure 5) provides then N (i) , t , N< d ), t and N< G >, t . 

These informations, together with the data provided by the above TABLE are then passed through a second com- 
puting stage 51, wherein the parameters a', t . a M | t , p', )t and p M , t are computed according to the above mentioned equa- 
30 tions 1 through 4, respectively. 

Finally, the a and p parameters, are fed into a third computing stage 52, together with the Explicit Rates for link I 
and the number of Non-Reserved traffics N NRI , to enable computing the updated available bandwidth B, t according to 
equation 5. 

The above computing operations of stages 50, 51 and 52 are performed for every link I. 
35 Then, for every connection along the considered path, and depending whether the state of the connection as 
defined by the measure of utilization is: decrease, no change, (i. e. keep even), or increase, then the link rate is updated 
according to equations 6, 7 or 8 respectively, as indicated in stages 53, 54 and 55 of figure 5 (and device 37 in figure 3). 

Finally, the new token rate for link k (see device 34 in figure 3), is computed in stage 56 through computation of 
equations (9) and (10). 

40 This new token generation rate R k t is then applied to update the token generation rate for the token pool 33 (see 
figure 3). 

Claims 

45 1. An adaptive bandwidth allocation method for optimizing data traffic in a high speed data transmission network 
including Nodes interconnected by high speed links made for vehiculating data traffics of different priority levels 
along assigned network paths between data terminal equipments acting as data sources and data destination ter- 
minals, said priority levels including high priority level(s) for so-called Reserved traffic for which a transmission 
bandwidth has been reserved along said path based on predefined agreements, and low priority level for so-called 

so Non- Reserved traffic which should be transferred over the network with the transmission bandwidth available along 

the considered path once Reserved traffic is satisfied, said method for assigning bandwidth to Non-Reserved traffic 
including : 

generating at least one Topology Data Base storing image of the network occupancy over each link along the 
55 network paths; 

periodically and at any terminal call set-up within the network, generating and broadcasting Topology Data 
Base updating (TDUs) messages and storing in said at least one Topology Data Base said TDUs, said TDU 
messages including a so-called Explicit Rate parameter (ER,) for each link I indicating the bandwidth currently 
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available on link I, and a parameter N NR indicating the number of Non-Reserved connections on link I; 

upon receiving said TDUs information, computing for each node along the considered path the amount of 
transmission bandwidth left available over each link along the considered path and assigning said available 
5 bandwidth to the Non-Reserved traffic sources connected to the network. 

2. A adaptive bandwidth allocation method according to claim 1 wherein said transmission network is a distributed 
control network said Topology Data Base being stored into each network node and said TDUs being broadcasted 
to said nodes along the considered path, said bandwidth available for Non- Reserved traffic being computed and 

io assigned to concerned links within each node along the path. 

3. An adaptive bandwidth allocation method according to claims 1 or 2 including the following steps : 

a - for all connections k over a link I, mark periodically and at any connection set-up, the connections as requir- 
15 ing an increased (i) bandwidth or a decreased (d) bandwidth, or no change (e) ; 

b - for all links I attached to a node along the considered path 

compute the number of connections requesting more bandwidth (N ( /')), the number of connections requir- 
20 ing less bandwidth (N| t < d >) and the number of connections owning the amount of bandwidth they need 

<N,, t < 6 >) ; 

upon reception of a TDU message, update the available bandwidth : 

(1 -(Rho),/ 63 )^- £MCR k 
B '.< N ~ N ' 

N NRI 

wherein 

N| is the number of Non-Reserved connections attached to the local ports that have link I in their 

path ; 

(Rho) res | t is the bandwidth ratio for reserved traffic on link I at time t, statistically monitored on the network 
nodes considered. 

C, is the link I speed ; 

N NR j is the total number of Non-Reserved connections within the network that have link I on their 

path. 

MCR k is the fraction of bandwidth "reserved" for Non Reserved traffic of connection k. (Eventhough 

this parameter MCR k should be null for Non- Reserved traffic, one may optionally reserve a fair 
minimum bandwidth anyway, for that traffic). In other words 

^ MCR k would be the sum of the Minimum Cell Rates 



30 



35 



40 



50 



55 



Compute 



Z R(d Vv E R( Vi*nd 
j=i j=i 
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5 



10 



20 



25 



30 



J (e, it 



K IJ.M 
j=1 



c - for all connections and for all links in connection path update R| k t as follows : 
if decrease required : 

, 0)2 M (i) M (e). 



R - B " TR< d > M N M N "MN^I,t 

R| - k - , -BT: IR w-i (1 "^2 T2 H 



if no change required : 



>i.m " N | N' , 



.(02 m(0 N(d, i.t 



R M ^ £ Ki I'J 
R _HjL_r R (e) /•*_ [A ^ My V R ( d ) i 

R uu- Bit lkmO — —)+— 2-x X R |J,m] 



M-1 N , N'l j=1 



if increase required 



N(i) 1>t N(d) 1(t 

R l,k,t = - S R(i>l,;j,t-1 + ; C SR( d 'l, j,t-l 

Bl.t-1 N U) l,t 3 = 1 N 2 1 3 = 1 



+ 



E "^ {e) l, j.t-l > 3 

3 = 1 



35 and finally setting R k t = min { R| k t } 

4. A system for dynamically adapting transmission bandwidth allocation to data traffic over a high speed transmission 
network including switching nodes (SWO, SW1 ....) attached to at least one Control Point processing unit keeping at 
least one updated Topology Data Base representing an instaneous image of the network, said switching nodes 

40 being interconnected by high speed links (10, 11...) for vehiculating data traffic of different priority levels along 
assigned network paths between network connected data sources and destination terminals, said priority levels 
including a high priority level for so-called Reserved traffic for which a transmission bandwidth is reserved in each 
link along the path based on predefined conditions, and a low priority level for so-called Non-Reserved traffic which 
should be transfered over the network within the transmission bandwidth left available along the considered path 

45 once Reserved traffic is optimized, said system for dynamically assigning transmission bandwidth to Non-Reserved 

traffic including : 

an Access Control Function device including Access Control means (24) connected to each data traffic source 
(k) attached to the considered link "I" for monitoring the source traffic and measuring current utilization from 
so said connection k; 



a Connection Agent (CA) (31) connected to each Control Function device of a data traffic source attached to a 
same link "I" ; 

means for attaching said Control Agent device to said at least one Topology Data Base to get. therefrom, link 
informations on request ; 

first computing means (36) within said Connection Agent device for computing the portion of line bandwidth 
B| x-a currently allocated to each connection k on the considered link I ; 



12 

BNSDOCID: <EP 0781068A1_I_> 



EP 0 781 068 A1 



5 



io 6. 



15 



20 

7. 



8. 

25 



30 9. 



second computing (37, 34) for computing an updated rate R k t assignable to each Non-Reserved traffic source 
of each connection k attached to link I, through said Access Control Function means (24). 

A system for dynamically adapting transmission bandwidth allocation according to claim 3 in a distributed network 
system wherin each network node is assigned a Control Point device (CP) storing said Topology Data Base, said 
system being provide with means for broadcasting Topology Data base Updating messages (TDUs) including, for 
each considered link I, a so-called Explicit Rate (ERI) parameter indicating the current available bandwidth on link 
I, and a parameter N NR indicating the number of Non-Reserved connections currently attached to said link I. 

A system for dynamically adapting transmission bandwidth allocation, as claimed in claims 4 or 5 wherein said 
Control Function means (24) includes : 

a leaky bucket (32) connected to each data source connection k for receiving data packets therefrom and to be 
passed to next link on the considered path upon collecting a so-called token from a token pool (33) filled in at 
a token generation rate R kt ; 

means (35) for periodically monitoring the token pool (33) content with respect to predefined threshold levels 
and for measuring the considered connection k requirements based on the token pool level with respect to said 
thresholds. 

A system for dynamically adapting transmission bandwidth allocation as claimed in claim 6, wherein said token pool 
is duplicated to enable distinguishing between Reserved traffic and Non- Reserved traffic. 

A system for dynamically adapting transmission bandwidth allocation according anyone of claims 6 or 7 wherein 
said means (35) for measuring each connection utilization periodically, monitors the corresponding token pool level 
of filling with respect to a so-called low threshold (Thy and a so-called high threshold (TH H ) and generate accord- 
ingly an indication meaning whether the token pool filling rate should be increased (i), decreased (d), or not 
changed (e). 

A system for dynamically adapting transmission bandwidth allocation as claimed in claim 8, wherein said Control 
Agent device (31) includes : 

means (36) for measuring the portion B, t of bandwidth allocated to all the connections for every link I, 



wherein = ER ( is the Explicit Rate for link I 

N| is the number of Non- Reserved connections attached to the nodes that have link I on their 
path, 

rate updating means (37) connected to said B| t measuring means (36) and to said measure of utilization 
means (35) for computing the rate to be assigned to packet transfers on every connection k over link I at time 
t, based on previous value (R| kt . 1 ) at time t-1 and increase/decrease/no change indications provided by means 
(35) 

whereby : 
for decrease : 



B| t = ER | x N 




11 



i, t-1 



[ R l,k,M a 'l,t] 



for no change : 



B 



i.t 




R 



a'Yt+P'ul 



l.t-1 



for increase : 
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N(i) lft 

B l t 1 

ii f k,t = _ c -nn— S rfl)l 'J't-i + Plt3 

j = i 



wherein : a' and a" are predefined multiplicative decrease factors 
p' and p" are predefined additive increase factors, 

is wherein the indexes (d), (e), (i) respectively identify the connections that can release some of their bandwidths, 

those which own the bandwidth they need, and those asking for more bandwidth as indicated by devise (35) ; 

means (34) for setting the updated token generation rate for connection k to the minimum rate along its path : 

20 Rk,i=min(R likit } 

1 0. A system for dynamically adapting transmission bandwidth allocation as claimed in claim 9. Wherein the minimum 
fraction of bandwidth MCR k reserved for Non- Reserved connection is made equal to zero. 

25 1 1. A system for dynamically adapting transmission bandwidth allocation as claimed in claim 9 wherein R k t is bound 
by MCR k and PCR k , with : 

R k t = max {MCR k , min {PCR k , R k M }} 

30 1 2. A system for dynamically adapting transmission bandwidth allocation as claimed in anyone of claims 9, 10 or 11 , 
wherein: 

N 0)2 N 0) N (e) |t 

«'i.t = 1 - —r 1 h 

35 N | N | 



a "l.t = 1 2 

N 



N * ... 



40 



45 



50 



55 



m N (d) 
M 0) N i,i 

«. _ M V R fd) 

P Lt " ..2 K lj.M 

N I j-l 



N(d) 1#t N(e) 1/t 



P"l,t = til- C 2- R( d U ft -l + ^ R (e) l.j,t-l > 

N 2 i j=l j=l 
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